//search模块小仓库
import {reqGetSearchInfo} from '@/api'

const state = {
    // searchList初始状态
    searchList: {}
};
const actions = {
    // 获取search模块数据
    async getSearchList({commit}, params={}) {
        // 当前这个reqGetSearchInfo这个函数在调用获取服务器数据的时候，至少传递一个参数（空对象）
        // params形参：是当用户派发action的时候，第二个参数传递过来的，至少是一个空对象
        let {data} = await reqGetSearchInfo(params)
        if (data.code == 200) {
            commit('GETSEARCHLIST', data.data)
        }
    }
};
const mutations = {
    GETSEARCHLIST(state, searchList) {
        state.searchList = searchList;
    }
};
// 计算属性：在项目当中，为了简化数据而生
// 可以把我们将来在组件当中需要用的数据简化一下【将来组件在获取数据的时候就方便了】
const getters = {
    // 当前形参state，是当前仓库中的state，并非大仓库的那个state
    goodsList(state) {
        // state.searchList.goodsList如果服务器数据回来了，没问题是一个数组
        // 假如网络不给力 | 没有网 state.searchList.goodsList应该返回的是undefined
        // 计算新的属性的属性值至少给人家来一个数组
        return state.searchList.goodsList || []
    },
    trademarkList(state) {
        return state.searchList.trademarkList
    },
    attrsList(state) {
        return state.searchList.attrsList
    }
};

export default {
    state,
    mutations,
    actions,
    getters
}